<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>事件处理</title>
</head>
<body>
    <!-- 准备好一个“容器” -->
    <div id="test1"></div>
    <!-- 引入react核心库 -->
    <script type="text/javascript" src="../js/react.development.js"></script>
    <!-- 引入react-dom，用于支持react操作DOM -->
    <script type="text/javascript" src="../js/react-dom.development.js"></script>
    <!-- 引入babel，用于将JSX转为JS -->
    <script type="text/javascript" src="../js/babel.min.js"></script>
    <script type="text/babel">
        //创建组件
        class Demo extends React.Component {
            /*
            （1）.通过onXxx属性指定事件处理函数（注意大小写）
                a.React使用的是自定义（合成）事件，而不是使用的原生DOM事件         ——————————为了更好的兼容
                b.React中的事件是通过事件委托方式处理的（委托给组件最外层的元素）   ——————————为了高效
            （2）.通过event.target得到发生事件的DOM元素对象                      ——————————不要过度的使用Ref
            */
            //创建ref容器
            
            myRef = React.createRef()
            myRef2 = React.createRef()

            //展示左侧输入框的数据
            showData = ()=>{
                console.log(this.myRef.current.value)
                alert(this.myRef.current.value)
            }

            //展示右侧输入框的数据
            showData2 = (event)=>{
                console.log(event)
                alert(event.target.value)
            }

            render(){
                return(
                    <div>
                        <input ref={this.myRef} type="text" placeholder="点击按钮提示数据"></input><br/>
                        <button onClick={this.showData}>点我提示左侧的数据</button><br/>
                        <input onBlur={this.showData2} type="text"/>
                    </div>
                )
            }
        }
        //渲染组件到页面
        ReactDOM.render(<Demo/>,document.getElementById('test1'))
    </script>
</body>
</html>